<template>
  <div v-if="flag">
    <h2>物流相关信息</h2>
    <div class="logistics-info-header">
      <div class="logistics-info-header-left">
        <div class="logistics-status blue" :style="{ color: yyx }">
          {{ order }}
        </div>
        <div class="logistics-company">{{ orderInfo.logisticsCompany }}</div>
        <div class="logistics-no">{{ orderInfo.logisticsNo }}</div>
      </div>
    </div>
    <ul class="logistics-info-list">
      <li v-for="item in orderInfo.logisticsInfo" :key="item.time">
        <div class="logistics-info-list-time">
          {{ item.time }}
        </div>
        <div class="logistics-info-list-content">
          {{ item.content }}
        </div>
      </li>
    </ul>
    <button v-role="orderInfo.role">查看物流详情</button>
  </div>
</template>

<script>
export default {
  data() {
    return {}
  },
  props: {
    flag: {
      type: Boolean,
    },
    orderInfo: {
      type: Object,
    },
  },
  directives: {
    role: {
      inserted(el, { value }) {
        // console.log(el)
        // console.log(value)
        const res = ['admin', 'zhangsan', 'lisi'].includes(value)
        el.disabled = !res
      },
    },
  },
  computed: {
    order() {
      switch (this.orderInfo.logisticsStatus) {
        case 0:
          return '未发货'
        case 1:
          return '已发货'
        case 2:
          return '已签收'
        default:
          return '未签收'
      }
    },
    yyx() {
      switch (this.orderInfo.logisticsStatus) {
        case 0:
          return 'skyblue'
        case 1:
          return 'red'
        case 2:
          return 'yellow'
        default:
          return 'green'
      }
    },
  },
}
</script>

<style scoped>
.logistics-info {
  border: 1px solid #ccc;
  border-radius: 5px;
  box-shadow: 0px 0px 10px #eee;
  padding: 10px;
  font-size: 14px;
}

.logistics-info-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.logistics-info-header-left {
  display: flex;
  align-items: center;
}

.logistics-status {
  font-weight: bold;
  font-size: 16px;
  color: #007bff;
}

.logistics-company,
.logistics-no {
  margin-left: 10px;
  font-size: 14px;
  color: #333;
}

.logistics-info-list {
  list-style: none;
  padding: 0;
  margin: 0;
  max-height: 230px;
  overflow-y: auto;
}

.logistics-info-list li {
  display: flex;
  margin-bottom: 10px;
}

.logistics-info-list-time {
  font-size: 12px;
  color: #999;
  width: 80px;
  text-align: right;
  margin-right: 10px;
}

.logistics-info-list-content {
  font-size: 14px;
  color: #333;
}
</style>
